<template>
  <div>
    <loginLogo/>
    <div class="signUp">
      <div class="signUp-head">
        <span>用户注册</span>
      </div>
      <el-form ref="registerForm" :model="registerForm" label-width="80px" :rules="rules">
        <el-form-item prop="username" label="用户名">
          <el-input v-model="registerForm.username" placeholder="用户名"></el-input>
        </el-form-item>
        <el-form-item prop="password" label="密码">
          <el-input type="password" v-model="registerForm.password" placeholder="密码"></el-input>
        </el-form-item>
        <el-form-item prop="sex" label="性别">
          <el-radio-group v-model="registerForm.sex">
            <el-radio :label="0">女</el-radio>
            <el-radio :label="1">男</el-radio>
          </el-radio-group>
        </el-form-item>
        <el-form-item prop="phoneNum" label="手机">
          <el-input v-model="registerForm.phoneNum" placeholder="手机"></el-input>
        </el-form-item>
        <el-form-item prop="email" label="邮箱">
          <el-input v-model="registerForm.email" placeholder="邮箱"></el-input>
        </el-form-item>
        <el-form-item label="生日" prop="birth" size="mini">
          <el-date-picker type="date" placeholder="选择日期" v-model="registerForm.birth" style="width: 100%;"></el-date-picker>
        </el-form-item>
        <el-form-item prop="introduction" label="签名">
          <el-input v-model="registerForm.introduction" placeholder="签名"></el-input>
        </el-form-item>
        <el-form-item label="地区" prop="location" size="mini">
          <el-select v-model="registerForm.location" placeholder="地区" style="width: 100%;">
            <el-option v-for="item in cities" :key="item.value" :label="item.label" :value="item.value"></el-option>
          </el-select>
        </el-form-item>
        <div class="login-btn">
          <el-button @click="goback(-1)">取消</el-button>
          <el-button type="primary" @click="SignUp">确定</el-button>
        </div>
      </el-form>
    </div>
  </div>
</template>

<script>
  import loginLogo from '../components/LoginLogo'
  import {rules,cities} from '../assets/data/form'
  import {mixin} from '../mixins'
  import {SignUp} from '../api/index'
  export default {
    name: 'SignUp',
    mixins:[mixin],
    components:{
      loginLogo
    },
    data(){
      return{
        registerForm: {
          username: '',       //用户名
          password: '',       //密码
          sex: '',            //性别
          phoneNum: '',       //手机
          email: '',          //邮箱
          birth: '',          //生日
          introduction: '',   //签名
          location: ''       //地区
        },
        cities: [],            //所有的地区--省
        rules: {}               //表单提交的规则
      }
    },
    created() {
      this.rules = rules;
      this.cities = cities;
    },
    methods:{
      goback(index){
        this.$router.go(index);
      },
      SignUp(){
        let _this = this;
        let d = this.registerForm.birth;
        let datetime = d.getFullYear() + '-' +(d.getMonth() + 1) +'-' + d.getDate();
        let params = new URLSearchParams();
        params.append('username',this.registerForm.username);
        params.append('password',this.registerForm.password);
        params.append('sex',this.registerForm.sex);
        params.append('phoneNum',this.registerForm.phoneNum);
        params.append('email',this.registerForm.email);
        params.append('birth',datetime);
        params.append('introduction',this.registerForm.introduction);
        params.append('location',this.registerForm.location);
        params.append('avator','/img/user/user.jpg');

        SignUp(params)
          .then(res => {
            if(res.code == 1){
              _this.notify('注册成功','success');
              setTimeout(function(){
                _this.$router.push({path: '/'});
              },2000);
            }else{
              _this.notify('注册失败','error');
            }
          })
          .catch(err => {
            _this.notify('注册失败','error');
          })
      }
    }
  }
</script>

<style scoped lang="scss">
@import "../assets/css/sign-up";
</style>
